package com.sojson.dao.impl;

import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import javax.annotation.Resource;

import org.springframework.stereotype.Repository;

import com.sojson.base.impl.BaseDaoImpl;
import com.sojson.dao.ArticleCateDao;
import com.sojson.entity.po.ArticleCate;

/**
 * 文章分类表Dao实现类(目的:把分页插件从Service层分离,这样就不用每次调Dao接口都要分页)
 * 
 * @author liu
 * @date 2021-03-16
 */
@Repository
public class ArticleCateDaoImpl extends BaseDaoImpl<ArticleCateDao, ArticleCate> implements ArticleCateDao {

    @Resource
    private ArticleCateDao articleCateDao;

    /**
     * 单条插入
     * 
     * @param articleCate
     * @return
     * @throws SQLException
     */
    @Override
    public int insert(ArticleCate articleCate) {
        return articleCateDao.insert(articleCate);
    }

    /**
     * 批量插入
     * 
     * @param articleCate
     * @return
     * @throws SQLException
     */
    @Override
    public int insertList(List<ArticleCate> articleCates) {
        return articleCateDao.insertList(articleCates);
    }

    /**
     * 通过对象批量删除(物理删除)
     * 
     * @param articleCate
     * @return
     * @throws SQLException
     */
    @Override
    public int deleteByDto(ArticleCate articleCate) {
        return articleCateDao.deleteByDto(articleCate);
    }

    /**
     * 统计全部数量
     * 
     * @return
     * @throws SQLException
     */
    @Override
    public int countAll() {
        return articleCateDao.countAll();
    }

    /**
     * 查询所有
     * 
     * @return
     * @throws SQLException
     */
    @Override
    public List<ArticleCate> listAll() {
        return articleCateDao.listAll();
    }

    /**
     * 根据对象统计数量
     * 
     * @param articleCate
     * @return
     * @throws SQLException
     */
    @Override
    public int countByDto(ArticleCate articleCate) {
        return articleCateDao.countByDto(articleCate);
    }

    /**
     * 根据对象查询
     * 
     * @param articleCate
     * @return
     * @throws SQLException
     */
    @Override
    public List<ArticleCate> listByDto(ArticleCate articleCate) {
        startPageDefaultSort(articleCate);
        return articleCateDao.listByDto(articleCate);
    }

    /**
     * 通过id删除(物理删除)
     * 
     * @param id
     * @return
     * @throws SQLException
     */
    @Override
    public int deleteById(Integer id) {
        return articleCateDao.deleteById(id);
    }

    /**
     * 通过id列表删除(物理删除)
     * 
     * @param ids
     * @return
     * @throws SQLException
     */
    @Override
    public int deleteByIdList(ArrayList<Integer> ids) {
        return articleCateDao.deleteByIdList(ids);
    }

    /**
     * 通过id更新(全部更新)
     * 
     * @param articleCate
     * @return
     * @throws SQLException
     */
    @Override
    public int updateById(ArticleCate articleCate) {
        return articleCateDao.updateById(articleCate);
    }

    /**
     * 通过id列表更新(全部更新)(更新内容相同)
     * 
     * @param articleCate
     * @return
     * @throws SQLException
     */
    @Override
    public int updateStaticByIdList(ArticleCate articleCate) {
        return articleCateDao.updateStaticByIdList(articleCate);
    }

    /**
     * 通过id列表更新(全部更新)(更新内容不相同)
     * 
     * @param articleCates
     * @return
     * @throws SQLException
     */
    @Override
    public int updateChangeByIdList(ArrayList<ArticleCate> articleCates) {
        return articleCateDao.updateChangeByIdList(articleCates);
    }

    /**
     * 通过id更新(局部更新)
     * 
     * @param articleCate
     * @return
     * @throws SQLException
     */
    @Override
    public int updatePartialById(ArticleCate articleCate) {
        return articleCateDao.updatePartialById(articleCate);
    }

    /**
     * 通过id列表更新(局部更新)(更新内容相同)
     * 
     * @param articleCate
     * @return
     * @throws SQLException
     */
    @Override
    public int updateStaticPartialByIdList(ArticleCate articleCate) {
        return articleCateDao.updateStaticPartialByIdList(articleCate);
    }

    /**
     * 通过id列表更新(局部更新)(更新内容不相同)
     * 
     * @param articleCates
     * @return
     * @throws SQLException
     */
    @Override
    public int updateChangePartialByIdList(ArrayList<ArticleCate> articleCates) {
        return articleCateDao.updateChangePartialByIdList(articleCates);
    }

    /**
     * 通过id查询
     * 
     * @param id
     * @return
     * @throws SQLException
     */
    @Override
    public ArticleCate findById(Integer id) {
        return articleCateDao.findById(id);
    }

    /**
     * 通过id列表查询
     * 
     * @param ids
     * @return
     * @throws SQLException
     */
    @Override
    public ArrayList<ArticleCate> findByIdList(ArrayList<Integer> ids) {
        return articleCateDao.findByIdList(ids);
    }

    /**
     * 通过对象查询id列表
     * 
     * @param articleCate
     * @return
     * @throws SQLException
     */
    @Override
    public ArrayList<Integer> findIdByDto(ArticleCate articleCate) {
        return articleCateDao.findIdByDto(articleCate);
    }

    /**
     * 清空数据(物理清空)
     * 
     * @throws SQLException
     */
    @Override
    public void clear() {
        articleCateDao.clear();
    }

}